# GIMIX DMA III DOUBLE DENSITY DISK CONTROLLER #68

The GIMIX DMA (Direct Memory Access) DISK CONTROLLER has the capabilities needed to realize the full potential of todays sophisticated multi-user/multi-tasking operating systems such as OS-9 and UniFLEX.

#### FEATURES

- HIGH SPEED using bi-polar logic DMA circuitry for guaranteed operation at 2MHz. DMA transfers take place at full bus speed using 6809 cycle steal DMA. Once the required parameters are passed to the controller and DMA transfer is initiated the processor is free for other tasks. Interrupts can be generated to indicate the completion of the transfer.
- SINGLE AND DOUBLE DENSITY data storage on any combination of 5.25" and 8" floppy disk drives; single and double headed, single and double track density, up to 4 drives total.
- LOW ERROR RATES are insured by a phase-locked loop data recovery circuit (data separator) and adjustable write precompensation circuitry for drives that require precomp. Separate precomp adjustments are provided for 5.25" and 8" drives.
- ADDRESSABLE to any 8 byte boundary in the address space (1M byte when extended address decoding is used). It occupies only 8 bytes of address space.
- EXTENDED ADDRESSING control using the SS-50C extended address lines. Control of the extended address lines allows the board to perform DMA transfers to and from any address in the 1M byte address space.
- FULLY BUFFERED with separate 5.25" and 8" output buffers and schmidt trigger input buffers for the disk drive signals.

SUPPORTS 3ms. STEP RATES for 5.25" 80 track (96 TPI) drives.

The DMA controller leaves the processor free to perform other tasks once the transfer is initiated, unlike programmed I/O disk controllers which require full time use of the processor during data transfers to and from disk. This is extremely important in a multi-user/ multi-tasking environment as the processor can perform other tasks such as console I/O while a disk transfer is in progress.

Note: The GIMIX DMA III disk controller is an updated version of the original GIMIX DMA controller #68. The DMA III is functionally equivalent to, and can be used as a direct replacement for, the original GIMIX DMA controller without hardware or software modifications.

•1983 GIMIX INC. 1337 W. 37th. PL. CHICAGO IL 60609 (312) 927-5510

### JUMPER OPTIONS

15

| $JA-1 \\ JA-2 \\ JA-3 \\ JA-4 \\ JA-5 \\ JA-6 \\ JA-7 \\ JA-8 \\ JA-10 \\ JA-11 \\ JA-12 \\ JA-13 \\ JA-13 \\ JA-14 \\ JA-15 \\ JA-16 \\ JA-17 \\ JA-18 \\ JA-20$ | (READY)<br>(HEAD LOAD<br>(DRIVE SEL<br>(DRIVE SEL<br>(SIDE SELE<br>(PRECOMP).<br>(MOTOR-ON<br>(HEAD LOAD<br>(SOFTWARE<br>(RESERVED)<br>(BA/BS)<br>(6800/6809<br>(SLOW MEMO<br>(INTERRUPT<br>(8" MOTOR<br>(8" HEAD L<br>(TEST POIN<br>(DMA EXTEN | ))<br>ECT #3)<br>ECT)<br>CT)<br>DELAY).<br>DELAY).<br>WRITE PI<br><br>DMA)<br>S)<br>CONTROL<br>OAD DELA<br>TS) | ROT)                                            |                   |                     | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------------------|---------------------|-------------------------------------------------------|
| DIP-SWITCH                                                                                                                                                        |                                                                                                                                                                                                                                                 |                                                                                                                |                                                 |                   |                     |                                                       |
|                                                                                                                                                                   | SING (S1,S2<br>DR 8" SENSE<br>TENDED ADDR                                                                                                                                                                                                       | SW (S:                                                                                                         | 2-91                                            |                   |                     | ••• O                                                 |
| BOARD REGIS                                                                                                                                                       | TERS                                                                                                                                                                                                                                            | ·                                                                                                              |                                                 |                   |                     |                                                       |
| DRIVE S<br>DMA STA<br>DMA CON                                                                                                                                     | DESCRIPTI<br>SELECT REGI<br>TUS REGIST<br>TROL REGIS<br>RTING ADDR                                                                                                                                                                              | STER<br>ER<br>TER                                                                                              |                                                 | • • • • • • • •   | <br>                | ··· 9<br>·· 10<br>·· 11                               |
| PROGRAMMING                                                                                                                                                       | FOR THE C                                                                                                                                                                                                                                       | ONTROLLI                                                                                                       | ER                                              |                   |                     |                                                       |
| HEAD LO                                                                                                                                                           | CRS AND FLA<br>DAD DELAY                                                                                                                                                                                                                        |                                                                                                                |                                                 |                   |                     | . 14                                                  |
| ADJUSTMENTS                                                                                                                                                       |                                                                                                                                                                                                                                                 | • • • • • • • •                                                                                                |                                                 | • • • • • • •     | •••••               | . 15                                                  |
| DISK DRIVE                                                                                                                                                        | CONFIGURAT                                                                                                                                                                                                                                      | ION                                                                                                            |                                                 |                   | • • • • • • • • • • | . 17                                                  |
| FIGURES                                                                                                                                                           |                                                                                                                                                                                                                                                 |                                                                                                                |                                                 |                   |                     |                                                       |
| FIG. 2<br>FIG. 3<br>FIG. 4<br>JUMPER<br>JUMPER<br>COMPONE                                                                                                         | (SWITCH CO<br>(SWITCH CO<br>(SWITCH CO<br>(ADJUST/TE<br>OPTIONS DR<br>OPTIONS DR<br>ENT LAYOUT.                                                                                                                                                 | NFIGURA<br>NFIGURA<br>ST POIN<br>AWING SH<br>AWING SH                                                          | FION OS<br>FION Un<br>FS)<br>HEET 1.<br>HEET 2. | -9 GMX<br>iFLEX). | 1 1 1 )             | . 7<br>. 15<br>. 18<br>. 19<br>. 20                   |

PAGE

1

#### JUMPER OPTIONS

The controller has several option jumpers which must be properly set before the board can be used. Several of the options are related to the type of drives being used. In most cases proper jumper settings for several different drives are given. If the drives being used are not listed, the drive manufacturer. documentation should be consulted to help determine the proper settings. The remaining option jumpers are related to the operating system software and the system hardware configuration. The proper jumper settings for use with GIMIX versions of 6809 FLEX are listed in this manual. For other operating systems consult the software documentation for information on proper settings for these jumpers.

## 5.25" READY OPTION JUMPER (JA-1)

While most 5.25" drive manufacturers use "standard" pinouts for their drive cables, some drives have non-standard pinouts for features not found on all drives. In particular; MICROPOLIS and BASF drives use pin 6 for the READY output from the drive. MICROPOLIS uses pin 34 for the fourth DRIVE SELECT input. Other drives, such as QUME and the SHUGART'SA410/SA460, use pin 34 for READY and pin 6 for the fourth DRIVE SELECT.

Jumper area JA-1 (see sheet 1 of the jumper options drawings), in conjunction with JA-3 (below), reconfigures pins 6 and 34 of the 5.25" drive connector J-1 as required by the drives being used.

When 5.25" drives without a READY output are used this option must be disabled as in Figure D. Figures B and C show the proper jumper settings for several drives that have a READY output.

### 5.25" HEAD LOAD OPTION (JA-2)

MICROPOLIS drives have a separate HEAD LOAD input on pin 2 of the drive cable. JA-2 (see sheet 1, figure E of the jumper options drawings) should be set according to either figure F or G depending on the drives being used.

## 5.25" DRIVE SELECT #3 OPTION JUMPER (JA-3)

Most 5.25" drives use pin 6 of the drive cable as the fourth DRIVE SELECT input (drive #3). MICROPOLIS drives use pin 34 for this input. JA-3 (see sheet 1, figure H of the jumper options drawings) should be set according to either figure I or J depending on the drives being used.

-1-

### DRIVE SELECT OPTION (JA-4)

This option enables the drive select outputs of the controller either: whenever the MOTOR-ON line is active (drive motors are on), or only when the HEAD-LOAD output of the 2797is In the drive select with motor-on position (see sheet 1, active. figure M of the jumper options drawings) the drive select outputs the controller are enabled whenever the motors are on. This of configuration is preferred when double headed drives are used, as limits the number of times the heads are loaded and unloaded. it In the drive select with head load position (see sheet 1, figure L jumper options drawings) the drive select outputs of the the of controller are only enabled when the HEAD-LOAD output of the 2797 This configuration is preferred when using single active. is headed drives.

### SIDE SELECT OPTION JUMPER (JA-5)

This option allows the side select output, for double headed drives, to be controlled by either the side select output of the 2797 or by bit 6 in the boards DMA CONTROL REGISTER. This option is factory jumpered for side select from the DMA CONTROL REGISTER (see sheet 1, figure P of the jumper drawings). This is the standard configuration for GIMIX FLEX, OS-9, and UniFLEX. If special applications require side select from the 2797, a trace must be cut and a solder jumper added to connect the pads per sheet 1, figure 0.

## 5.25" and 8" PRECOMP OPTION JUMPER (JA-6)

Write Precompensation (precomp) is recommended by many drive when their drives are used for double density manufacturers, recording. Some drives require precomp on all tracks; certain 8" and 5.25" 96 TPI (80 track) only require precomp on tracks greater than track #43. JA-6 (see sheet 1, figure T of the jumper options drawings) selects the proper precomp option(s) for the drives being used. Figures U, V, and W show the options for 5.25" drives, figures X and Y for 8" drives. If a combination of 5.25" and 8" drives is used, jumpers should be installed to select the proper option for both sizes. For example: if 5.25" drives that require precomp on all tracks and 8" drives that require precomp are combined, install jumpers as shown in BOTH figures V AND Y. If only one size drive is used, install the appropriate jumper for size drive. The second jumper should be installed at any of that the positions for the unused drive size.

a certain amount of precomp; Drive manufacturers specify The board has provisions for usually between 100 and 400 ns. separately adjusting the amount of precomp for 5.25" and 8" drives. If the controller is purchased as part of a complete disk based system, the precomp is factory adjusted for the drives If purchased separately, the controller is adjusted to supplied. for 5.25" drives and 250 ns. for 8" drives, or to the 150 ns. requirements of the drives being used, if specified when the The adjustments section explains the controller was ordered. procedure for adjusting the board for the required precomp. the manufacturers literature to determine the precomp Consult requirements of the drives being used.

## 8" MOTOR-ON DELAY OPTION JUMPER (JA-7)

Disk drives normally require a certain amount of delay for the motors to come up to speed after they are started. This delay is provided by a timing circuit on the controller. If 8" drives that do not have motor control (the motors are always running) are used this delay can be eliminated. JA-7 (see sheet 1, figure Q of the jumper options drawings) enables or disables the motor-on delay as required.

If 8" drives without motor control are used position the jumper as shown in figure R. If drives with motor control are used position the jumper as shown in figure S.

5.25" HEAD-LOAD DELAY OPTION JUMPER (JA-8)

Most disk drives have a solenoid that loads and unloads the head(s). These drives require a delay, after the heads are loaded, to allow time for the head(s) to settle. This delay is provided by a timing circuit on the controller. Some 5.25", double headed drives do not have a head load solenoid and the head is loaded as soon as the door is closed. These drives do not require any head load delay.

JA-8 (see sheet 2, figure A, of the jumper options drawings) allows the 5.25" head-load delay to be disabled when drives without head-load solenoids are used, figure B, or enabled for drives with a head-load solenoid, figure C.

Note: JA-17 performs a similar function for 8" drives.

JA-9 NOT USED

SOFTWARE WRITE PROTECT OPTION (JA-10)

sheet 2, figure D, of the jumper options drawings), in conjunction with bit 4 of the boards DRIVE SELECT (see the disk drives to be write protected under REGISTER, allows When this option is enabled, figure F, and bit software control. SELECT REGISTER is set low (0), all drives are 4 of the DRIVE write protected and no disk write operations are possible until bit 4 is set high (1). Since all bits in the DRIVE SELECT REGISTER are set low on system power up, bit 4 must be set high after power up to enable disk writes. When this option is disabled, figure E, write protect is controlled only by the write protect signals from the individual drives.

JUMPER AREA (JA-11) is reserved for future use.

€1983 GIMIX Inc.

REV A 2-23-83

-3-

### BA/BS OPTION JUMPER (JA-12)

DMA transfers to and from the board require a signal from the processor indicating that the bus is available to the controller. This signal is provided by the BUS AVAILABLE (BA) and BUS STATUS (BS) lines of the 6809. JA-12 (see sheet 2, figure J, of the jumper options drawings) is used to select either normal 6809 (BA/BS) , figure K, or BA only, figure L, operation. JA-12 is factory jumpered for 6809 operation, figure K.

### DMA OPTION JUMPER (JA-13)

JA-13 (see sheet 2, figure M, of the jumper options drawings) selects either of two DMA methods, HALT or CYCLE STEAL. This jumper is factory programmed for cycle steal DMA per figure O. Halt DMA is not used except for special applications.

## SLOW MEMORY OPTION JUMPER (JA-14)

Because of the timing requirements of the 2797, slow memory (MRDY) circuitry is required, at bus speeds above 2 MHz, to stretch the system clock whenever the 2797 is accessed. JA-14 (see sheet 2, figure P, of the jumper options drawings) enables or disables the generation of slow memory cycles as required.

In systems operating at 2 MHz. or slower JA-14 should be jumpered as shown in figure Q (slow memory disabled). For systems operating above 2 MHz. jumper JA-14 as shown in figure R (slow memory enabled).

## INTERRUPT OPTION JUMPER (JA-15)

JA-15 (see sheet 2, figure S, of the jumper options drawings) is used to connect the interrupt output (INTRQ) from the 2797 to one of the interrupt lines of the bus. This jumper is factory configured for IRQ interrupts (figure U). Since interrupts can be enabled or disabled under software control (by the interrupt enable bit in the DMA Control Register) this jumper can be left in place for non-interrupt driven applications such as FLEX.

## 8" MOTOR CONTROL OPTION (JA-16)

JA-16 (see sheet 2, figures W,X, and Y of the jumper options drawings) is used to select the polarity of the motor control output (MOTOR ON) at pin 4 of J2, the 8" disk drive cable connector. For most 8" drives, or for use with the AC motor control circuit in the GIMIX 8" DISK CABINET, the jumper should be installed as shown in figure Y, the NORMAL position. In the NORMAL position, the output goes LOW when the motors are to be turned ON. Some 8" drives, the Tandon balf height drives for example, require that the motor control signal go HIGH to turn the motors ON. For use with these drives, the jumper should be installed as shown in figure X.

### 8" HEAD LOAD DELAY OPTION (JA-17)

Most disk drives have a solenoid that loads and unloads the head(s). These drives require a delay, after the heads are loaded, to allow time for the head(s) to settle. This delay is provided by a timing circuit on the controller. Some 8" drives do not have a head-load solenoid; the head is loaded as soon as the door is closed. These drives do not require any head-load delay.

JA-17 (see sheet 2, figure Z, of the jumper options drawings) allows the 8" head-load delay to be disabled when drives without head-load solenoids are used, figure AA, or enabled for drives with a head-load solenoid, figure BB.

Note: JA-8 performs a similar function for 5.25" drives.

# DMA EXTENDED ADDRESS COUNTER OPTION (JA-20)

JA-20 (see sheet 2, figure CC of the jumper options drawings) allows the option of having the extended address output from the board (when enabled by Dip-switch S2-10) increment as part of the DMA source/destination address, or remain fixed. The initial value is determined by the value stored in the lower 4 bits of the DMA Control Register. Enabling this option allows DMA transfers to cross a bank address boundary. For example, with this option enabled and a 4K transfer started at address \$F800 on bank \$A; after the address counter reached \$FFFF the extended address would become \$B and the remaining 2K would be transferred bank \$B to If this option is disabled, the beginning at address \$0000. extended address would remain fixed at \$A for the entire transfer. earlier versions of the GIMIX DMA Controller did not have Note: this option; the extended address output did not increment. This option factory enabled (figure DD). For special applications where this feature is not desired, remove the factory jumper and install a jumper per figure EE.

-5-

ADDRESSING OPTIONS (S1 and S2 sections 1 through 8)

The board occupies 8 bytes of address space (4 for the board registers and 4 for the 2797 registers) and can be addressed to any 8 byte boundary in the address space. Extended address decoding (SS-50C) is provided. DIP-switch S1 section 1 (S1-1) enables or disables the extended address decoding for the board.

is OFF (OPEN) extended address decoding is disabled Τf S1-1 and the board only decodes the 16 regular address lines, A0 DIP-switch S1 sections 6 through 10 correspond to through A15. address lines A3 through A7 respectively. DIP-switch S2 sections correspond to address lines A8 through A15 8 through 1 respectively. These switches must be set to the desired base address of the board. A switch set ON (CLOSED) corresponds to a 1 (HIGH) on that address line and a switch set OFF (OPEN) corresponds to a O (LOW).

If S1-1 is ON (CLOSED) the board decodes all 20 SS-50C address lines, A0 through A19 and, in addition to setting the base address of the board, S1-2 through 5 must be set to the desired extended address. DIP-switch S1 sections 2 through 5 correspond to the extended address lines A16 through A19 respectively. A switch set ON (CLOSED) corresponds to a 1 (HIGH) on that address line. A switch set OFF (OPEN) corresponds to 0 (LOW).





FIGURE 2

# UNIFLEX CONFIGURATION

## ADDRESS=\$FFØØØ



## FIGURE 3

\* See the UniFLEX documentation for the function of this switch.

# 5.25" or 8" SENSE SWITCH (S2 section 9)

Bit 0 of the DRIVE SELECT REGISTER is provided to allow the size (5.25" or 8") of the drive installed as drive 0 to be determined by software. The status of this bit is determined by setting S1-9. If drive 0 is a 5.25" drive, S1-9 should be set ON (CLOSED). If drive 0 is an 8" drive, set S1-9 OFF (OPEN). Note: UniFLEX systems may use this switch for other functions. See the UniFLEX documentation for more information.

# DMA EXTENDED ADDRESS OPTION (S2 section 10)

The board is capable of driving the SS-50C extended address lines, A16 through A19, during DMA transfers. allows the This board to perform DMA transfers to and from any address in the 1M byte address space of the SS-50C bus. If S2-10 is OFF (OPEN) this option is disabled and the controller only drives the 16 regular the If S2-10 is ON (CLOSED) address lines AO through A15. all 20 address lines of the SS-50C bus. The controller drives address presented on the 4 extended address lines is determined by data stored in the lower 4 bits of the DMA CONTROL REGISTER. the 3 of the DMA CONTROL REGISTER correspond to Bits O through A16 through A19 respectively. If the extended address lines Extended Address Counter Option is enabled by JA-20 (the normal factory configuration) the extended address output will increment after the DMA source/destination address reaches \$FFFF, allowing DMA transfers to begin on one bank and continue on the next.

### BOARD REGISTERS

The board occupies 8 memory locations and can be addressed to any 8 byte boundary in the 1 megabyte address space. The table below lists the functions of the 8 bytes and assumes the board is at the GIMIX FLEX/OS-9 address, \$E3B0.

| Base address      | \$E3B0                                                             | Drive Select Register (write)<br>DMA Status Register (read)                                                                                                                                                                      |
|-------------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Base address +7   | \$E3B1<br>\$E3B2<br>\$E3B3<br>\$E3B4<br>\$E3B5<br>\$E3B6<br>\$E3B7 | DMA Status Register (road)<br>DMA Control Register (write only)<br>DMA Starting Address (MSB)<br>DMA Starting Address (LSB)<br>2797 Command/Status register<br>2797 Track Register<br>2797 Sector Register<br>2797 Data Register |
| , Dase audress in | $\varphi = \varphi$                                                |                                                                                                                                                                                                                                  |

The last four are the internal registers of the 2797 floppy disk controller I.C. Information on their functions and programming can be found in the manufacturers data sheets for the 2797.

NOTE: Accessing (read or write) any of the 2797 registers or writing to the DRIVE SELECT REGISTER starts the drive motors.

The first four registers control various functions as described below (addresses in parentheses are for GIMIX FLEX/OS-9).

8\_

DRIVE SELECT REGISTER (\$E3B0 Write only)

| MSB | BIT 7 | RESERVED                                             | Reserved for future use.                                                                                                               |
|-----|-------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
|     | BIT 6 | CONNECTOR SELECT<br>$0 = 5 \cdot 25''$<br>1 = 8''    | Selects between the 5.25" and 8"<br>drive connectors. Also selects<br>the proper data separator rate<br>and precomp.                   |
|     | BIT 5 | DENSITY SELECT<br>O = Double den.<br>1 = Single den. | Selects between single and dou-<br>ble density operation. Selects<br>proper data separator rate and<br>enables precomp for double den. |
|     | BIT 4 | WRITE PROTECT<br>O = W/protect<br>1 = W/enable       | Write protects all drives when<br>enabled. SOFTWARE WRITE PROTECT<br>OPTION JA-10 must be enabled to<br>use this feature.              |
|     | BIT 3 | DRIVE SEL. 3                                         | Bits O through 3 perform a<br>1 of 4 drive select function.<br>Any bit set to a 1 selects                                              |
|     | BIT 2 | DRIVE SEL. 2                                         | the associated drive. Only one of the four drives select                                                                               |
|     | BIT 1 | DRIVE SEL. 1                                         | bits should be a 1 to prevent<br>multiple drives from being<br>selected.                                                               |
| LSB | BIT O | DRIVE SEL. O                                         | 1 = drive selected<br>0 = drive deselected                                                                                             |

Notes: All bits in the DRIVE SELECT REGISTER are cleared to O on power up and hardware reset.

Writing to this register will start the drive motors.

\_9\_

DMA STATUS REGISTER

. . ..... . . . . .

(\$E3B0 Read only)

interrupts are disabled.

This bit is the same as the DRQ BIT 7 DRQ FLAG bit in the 2797 status register and the output of the 2797 DRQ signal. See the 2797 data sheet. Indicates the state of the INTRQ BIT 6 INTRQ FLAG interrupt output from the 2797. This bit is set to a 1 when an 0 = NO INTRQinterrupt is generated an cleared 1 = INTRQto 0 when the 2797 status register is read. Active even when bus

- Indicates that the drive motors MOTOR DELAY FLAG BIT 5 were stopped then restarted. Used 0 = Runningto eliminate software timing when 1 =Starting checking for "drives ready".
- Indicates that DMA transfers are DMA ENABLED FLAG BIT 4 enabled and an occurence of the 0 = DMA Disabled 2797 DRQ will cause data to be 1 = DMA Enabled transferred between the board and memory.
- Indicates that a DMA transfer DMA FAULT FLAG BIT 3 longer than 16,384 + or - 256 bytes was attempted and the board O = NO DMA FAULThas stopped the transfer. This 1 = DMA FAULTcan occur because of a hardware fault or if a drive door is opened during a track write (formatting).
- NOTE: Data must be written to the DMA STARTING ADDRESS REGISTER (LSB) to reset the DMA FAULT counter and prevent false DMA FAULTS from occuring.
  - Indicates the drive size, 5.25" or CONNECTOR SELECT BIT 2 8", currently selected by the FLAG CONNECTOR SELECT bit in the 0 = 5.25''DRIVE SELECT REGISTER. 1 = 8''
- Reserved for future use BIT 1 RESERVED
- Indicates the state of the sense SENSE SWITCH FLAG LSBBIT 0 switch, S2-9. Used by FLEX and 0 = S2-9 OFF (8'')OS-9 to determine what size drive 1 = S2-9 ON (5.25) is installed as drive 0.

10

MSB

## DMA CONTROL REGISTER (\$E3B1 WRITE ONLY)

-----

ě

| MSB | BIT 7    | INTERRUPT ENABLE<br>O = Int. Disable<br>1 = Int. Enable  | Enables the interrupt output from<br>the board to the bus. Interrupt<br>jumper JA-15 must also be set for<br>the desired interrupt line. Allows<br>software switch between interrupt<br>and non-interrupt operation. |
|-----|----------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ·   | BIT 6    | SIDE SELECT<br>0 = Side Zero<br>1 = Side One             | Used to select between side zero<br>and side one when using double-<br>headed drives. Side select jumper<br>JA-5 must be set for side select<br>from control register in order to<br>use this bit.                   |
|     | BIT 5    | DMA DIRECTION<br>O = READ FROM DISK<br>1 = WRITE TO DISK | Sets the direction for DMA<br>transfers between disk and memory.                                                                                                                                                     |
|     | BIT 4    | DMA ENABLE<br>O = DMA DISABLED<br>1 = DMA ENABLED        | Enables the DMA circuitry for<br>transfers between disk and memory.<br>DMA must be enabled before a read<br>or write data command is issued<br>to the 2797.                                                          |
|     |          |                                                          | Bits 0 through 3 are used to set                                                                                                                                                                                     |
|     | BIT 3    | A19                                                      | the extended (bank) address that<br>will be placed on the bus by the                                                                                                                                                 |
|     | BIT 2    | A18                                                      | controller during DMA transfers.                                                                                                                                                                                     |
|     | BIT 1    | A17                                                      | To use extended addressing during<br>DMA transfers these bits must be                                                                                                                                                |
| TOD | <u> </u> | A16                                                      | set to the desired address and                                                                                                                                                                                       |

Notes: All bits in the DMA CONTROL REGISTER are cleared to 0 on power up and hardware reset.

OTOPS CIMIN INC.

and a second

LSB BIT 0 A16

-11-

REV A 2-23-83

switch S2-10 must be ON (CLOSED).

# DMA STARTING ADDRESS REGISTERS (\$E3B2 and \$E3B3 WRITE ONLY)

The source/destination address for a DMA transfer must be written to the DMA STARTING ADDRESS REGISTERS before a transfer is initiated by issuing a read or write command to the 2797. After each byte is transferred the address is automatically incremented and another byte is transferred, until the 2797 read or write The most significant byte of the 16 bit operation is complete. MSB register (\$E3B2) and the least address is stored in the significant byte in the LSB register If extended (\$E3B3). addressing (20 bit) is used, the extended address is written to CONTROL REGISTER bits 0 through 3 (see above). If the DMA the source/destination address counters reach \$FFFF, the next countwill cause the extended address to increment (unless this option is disabled, see JA-20), permitting DMA transfers to cross bank boundaries.

Writing to the DMA STARTING ADDRESS REGISTER (LSB) resets the DMA FAULT counter. This register must be rewritten before every DMA transfer to prevent a false DMA FAULT from occuring.

## PROGRAMMING FOR THE GIMIX DMA CONTROLLER

This section is included as a guide to the features of the board, for the user who wishes to write his own operating system or adapt the board to an existing operating system. Information on programming the 2797 can be found in the manufacturers literature.

### DRIVE SELECT REGISTER (WRITE)

The functions of the DRIVE SELECT REGISTER bits are described in the preceding section. On power up or after a system reset the following conditions exist: 5.25" drives, double density, and write protect of all drives is selected. All drives are deselected. Before a disk transfer is initiated the drive size, density, and write protect should be set as required and one of the drives selected by setting the appropriate drive select bit to a "1".

## DRIVE SELECT REGISTER (READ)

Reading the DRIVE SELECT REGISTER indicates the status of various functions of the board. The basic functions of the flags are described in the preceding section. More detailed information on those that have special significance is given below.

BIT 7: The DRQ FLAG is not normally used for DMA transfers, it is only required if the board is used as a programmed I/O controller.

BIT 6: In an interrupt driven system, the IRQ FLAG can be read to determine whether or not an interrupt was generated by the controller. This bit should also be used, instead of the busy bit in the 2797 status register, to determine when a command has been completed. This eliminates the need for a delay loop that makes the software dependent on system clock speed. The 2797 status register must be read to clear the IRQ FLAG. BIT 5: The MOTOR DELAY FLAG can be used in routines that check for "drives ready". Normally these routines include a delay loop to insure that a "drives not ready" condition is not caused because the drive motors are not yet up to speed. The MOTOR DELAY FLAG can be used to eliminate delay loops under certain conditions.

Note: The MOTOR DELAY FLAG should not be used when the software may be used with drives that automatically start their motors when they are selected instead of using the MOTOR ON signal from the controller. General purpose software should use appropriate timing loops to allow for motor startup delays.

To use the MOTOR DELAY FLAG, first check the "drives ready" this indicates that the drives are Ιf 2797. status from the ready, normal operation can proceed. If the drives are not ready, the MOTOR DELAY FLAG should be checked. If the MOTOR DELAY FLAG is LOW (0), the motors are at speed and the "drives not ready" can be considered valid and proper action taken to handle the error. If the MOTOR DELAY FLAG is HIGH (1), it should be rechecked until goes LOW (0). The HIGH to LOW transition indicates that the it drive motors have been on long enough to come up to speed. The "drives ready" status from the 2797 should again be checked and if "drives not ready" the condition can be it still indicates considered valid (no disk in the selected drive, door open, etc.) and proper action taken to handle the error. If it indicates that the drives are ready, normal operation can proceed.

BIT 3: Because the 2797 track read and track write commands read write data continuously, starting when one index pulse is received from the drive and ending on the next, it is possible for or control of a transfer to be lost because of a hardware failure or because the drive door is opened during a track write. If this were to occur the board would cycle continuously through the entire address range reading from memory. This runaway condition prevented by a counter which limits the maximum transfer to is If the maximum count is reached the 16,384 + or - 256 bytes. transfer is halted and the DMA FAULT FLAG is set HIGH (1) to indicate a DMA FAULT. The DMA FAULT FLAG should be checked at the completion of any 2797 track write commands to determine if a DMA FAULT has occurred. The DMA FAULT COUNTER is reset by writing to the DMA STARTING ADDRESS REGISTER (LSB). Data must be written to this register before each DMA transfer to reset the counter and prevent false DMA FAULTS.

### DMA CONTROL REGISTER

ŝ

The functions of the DMA CONTROL REGISTER are described in the preceding section. More detailed information for some of the bits is given below. On power up or after a system reset all bits are cleared to 0; interrupts are disabled, side 0 and read are selected, DMA is disabled, the extended address is set to \$0.

BIT 7: This bit enables and disables the interrupt output from the board to the bus. It does not affect the interrupt flags in the DRIVE SELECT REGISTER. In an interrupt driven system, this bit must be set by the software to enable bus interrupts. The desired interrupt must also be enabled by the interrupt jumper JA-15. This option allows switching between interrupt and non-interrupt driven software without reconfiguring the board. BIT 4: DMA must be enabled by setting this bit HIGH (1) before DMA transfers can take place. It must be set before a read or write command is issued to the 2797 or data will be lost.

## DMA STARTING ADDRESS REGISTERS (MSB and LSB)

The source or destination address for a DMA transfer must be written to these registers before the transfer is initiated. Once the transfer is started the board increments this address each time a byte is transferred. At the completion of a transfer the STARTING ADDRESS REGISTERS point to the address after the DMA If the Extended Address address of the last byte transferred. Option (JA-20) is enabled and the address increments past Counter \$FFFF the extended address will also be incremented by one. It is not necessary to write a new value to the MSB register if a second transfer is to be made, continuing from this address. The LSB register should be re-written, before each transfer or before 16,128 (16K-256) bytes have been transferred, to reset the DMA FAULT counter. IF THE DMA FAULT COUNTER IS NOT RESET BEFORE MORE THAN 16,128 BYTES ARE TRANSFERRED A FALSE DMA FAULT WILL OCCUR, HALTING DMA TRANSFER.

### HEAD LOAD DELAY

The board has two separate delay circuits, one for 5.25" drives and another for 8". The proper circuit is selected by the are used to provide the These delays CONNECTOR SELECT BIT. required settling time, after the heads have been loaded. The delay starts whenever the head load output from the 2797 (HLD) becomes active (HIGH). After the delay, the head load timing input to the 2797 (HLT) is made high indicating to the 2797 that the heads are loaded and have had time to settle. The HLT input also controlled by another delay circuit that provides a delay is for the drive motors to come up to speed. Both the HEAD LOAD MOTOR-ON delay must be completed before the HLD DELAY and the input is made HIGH.

Once the HLD output is made active (HIGH), by issuing a command to the 2797 that loads the heads, it does not become inactive (LOW) again until it is specifically reset by issuing a command that unloads the heads or until 15 revolutions of the disk have occurred since the 2797 completed its last command.

To insure proper operation of the HEAD LOAD DELAY circuit and reliable operation of the controller, the HLD output should be made inactive by issuing a command to unload the head each time a different drive is selected. Issuing a head load command will then restart the HEAD LOAD DELAY and allow the proper head settling time.

#### ADJUSTMENTS

### \*\*\*\*\* CAUTION \*\*\*\*\*

The GIMIX DMA III is completely calibrated at factory and the should not require recalibration unless the WD 2797 or the components in the adjustment circuits are replaced. Calibration of the board requires care and the proper test equipment. Before attempting to calibrate the board be sure that recalibration recalibration can seriously degrade Improper really necessary. The minimum equipment required for the performance of the board. calibration is an oscilloscope with an ACCURATE time base and a non-metallic adjustment tool for the trimmer capacitor (C-31). An ACCURATE frequency counter is also helpful but not absolutely necessary.

A total of 5 adjustments are required to completely calibrate the DMA III for both 5" and 8" disks. Following is a list of the step required to calibrate the board. The board should be installed in a functioning system with a monitor program, such as GMXBUG-09, that can be used to store the required values in the boards control registers. JA-18 provides convenient access to the test points required (see fig. 2).

The first four adjustments require monitoring the proper test point, with the oscilloscope set to trigger on the positive-going edge of the signal, and adjusting one of the four trimmer resistors (see fig. 2) for the required positive-going pulse width. The fifth adjustment requires monitoring a test point and adjusting trimmer capacitor C-31 (use a non-metallic adjusting tool) for the correct frequency.



### FIGURE 4

CINEY Inc.

REV A 2-23-83

| STEP | ACTION               | RESULT                            |
|------|----------------------|-----------------------------------|
| 1:   | Power-up system      |                                   |
| 2:   | Monitor TP-1         | 4 MHz $\pm 0.5\%$ square wave (1) |
| 3:   | Ground TP-5          | 2797 in adjustment mode           |
| 4:   | Monitor TP-4         | 5" Precomp adjustment             |
|      | Adjust R-61          | 150 ns. pulse at TP-4 (2)         |
| 5:   | Monitor TP-2         | 5" read pulse width adj.          |
|      | Adjust R-62          | 500 ns. pulse at TP-2             |
| 6:   | Write \$40 at \$E3B0 | Select 8" drive size (3)          |
| 7:   | Monitor TP-4         | 8" Precomp adjustment             |
|      | Adjust R-60          | 250 ns. pulse at TP-4 (2)         |
| 8:   | Monitor TP-2         | 8" read pulse width adj.          |
|      | Adjust R-63          | 250 ns. pulse at TP-2             |
| 9:   | Monitor TP-3         | Data Separator clock adj.         |
|      | Adjust C-31          | 500 KHz. sq. wave at TP-3         |
| 10:  | Un-ground TP-5       | Restore 2797 to normal mode       |

- (1): If the 4 MHz. clock is not present, the crystal oscillator circuit is defective; no further adjustments are possible until the problem is corrected.
- (2): These are standard precomp settings used by GIMIX, other values can be set by making the pulse width equal the desired precomp.
- (3): Assuming that the board is set to the standard base address for FLEX/OS-9 (\$E3B0). Use first board address if the board is set to a different address.

Note: Calibration requires a jumper connecting test point TP-5 to ground (the pin to the right of TP-5 on JA-18). The system should NOT be reset while this jumper is installed (TP-5 grounded). This causes the 2797 to enter a special state that prevents calibration or normal operation. If the system is inadvertently reset while TP-5 is grounded, reset the system with the jumper removed to restore the 2797 to its normal state.

#### DISK DRIVE CONFIGURATION

### DRIVE CONNECTIONS

34 pin (J1) and 50 pin (J2) connectors are provided Standard and 8" drive cables respectively. The proper for the 5.25" selected automatically when the controller is is connector switched between 5.25" and 8" drives using the CONNECTOR SELECT The length of the cables in the DRIVE SELECT REGISTER. bit between the controller and the drives should be kept to a minimum to reduce noise pickup. Ten feet should be considered an absolute maximum for the combined length of both cables.

#### DRIVE PROGRAMMING

Any combination of 5.25" and 8" drives, up to four drives total, can be connected to the controller. The drives themselves must be programmed to respond to the desired drive number (drive  $\tilde{0}$ ,  $\tilde{1}$ , 2, or 3). See the drive manufacturers documentation select for information on programming specific drives. If only one size drive is used the drives should be programmed in sequence starting with drive 0. If both 5.25" and 8" drives are used they can be arranged in any desired order starting with drive 0. For example: if two 5.25" and two 8" drives are used, the 5.25" drives could be programmed as drives 0 and 1, the 8" drives would then be 2 and 3, If the 8" drives were programmed as drives 0 and 1, 5.25" the then be programmed as 2 and 3. They could also be arranged would so that drives 0 and 2 are 8" and drives 1 and 3 are 5.25" etc. Regardless of the order chosen, the 5.25" or 8" SENSE SWITCH (S2 section 9) must be set to match the size of the drive programmed as drive 0.

### DRIVE TERMINATION

order for the controller to function properly, the drive In Terminating resistors are cables must be properly terminated. on the disk drives to terminate the cables. When more provided than one drive is connected to a single cable the terminating EXCEPT the last one on that cable (the resistors on all drives drive farthest from the controller) must have their terminating resistors removed or disabled. Only the last drive on the cable should have a terminator. If both 5.25" and 8" drives used are the last drive on both cables must have a terminator. Consult the drive manufacturers documentation for information on removing or disabling the terminators.



- Second

-



COMPONENT LAYOUT